# Freescale i.MX6 DRAM Port Application Guide – DDR3

This paper is written for how to design and initialize DDR3 on i.MX6 serial microprocessor.

Schematic and Layout design rules, DDR3 script (initialization code) generation aid, DDR calibration & stress test tool will be introduced.

#### **Contents**

| 1 | DRAM Design Consideration                 | 2  |
|---|-------------------------------------------|----|
| 2 | DDR3 initialization Script Generation Aid |    |
| 3 | DDR Stress Test Tool                      |    |
| 1 | Further Reading                           | 20 |

## 1 DRAM Design Consideration

FSL HW AE team had created "HW Design Checking List for i.Mx6" for sharing experience of i.Mx6 HW design.

Please find latest version through following link: https://community.freescale.com/docs/DOC-93819

## 1.1 Schematic and Layout Design Rules

The items in below table must be followed during design i.Mx6 platform. Please refer to "HW Design Checking List for i.Mx6" in above link for detailed info.

Designer should check these items one by one before or during his design.

Each item must be cleared by designer, If not sure please contact Freescale supporter for help.

|   | Schematic checking list                                                                                                                                                                          |  |  |  |  |  |
|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 1 | Connect all ZQPAD pins (i.Mx6 and DDR chip) to an external 240 ohm 1% resistor to GND.                                                                                                           |  |  |  |  |  |
| 2 | Connect DRAM_VREF to a source that is 50% of the voltage value of NVCC_DRAM. Please click "Ref5" for more info.                                                                                  |  |  |  |  |  |
| 3 | Connect DRAM_RESET to a 10 kohm 5% pull-down resistor to GND. Please click "Ref6" for more info.                                                                                                 |  |  |  |  |  |
| 4 | DRAM_SDCKE0 and DRAM_SDCKE1 should be connected to individual 10 kohm 5% resistors to GND. Please click "Ref7" for more info.                                                                    |  |  |  |  |  |
| 5 | Differential clock termination design rules, please click "Ref8" for more info.                                                                                                                  |  |  |  |  |  |
| 6 | LPDDR2 and DDR3 pin mux mapping. Please click "Ref9" for more info.                                                                                                                              |  |  |  |  |  |
| 7 | Suggest using "T" topology when the number of DDR chips is not more than four (two on top, two on bottom).  Otherwise "Fly-by" Topology is recommended for more than two chips on same PCB side. |  |  |  |  |  |
| 8 | Data bus/DQM and DQS of each byte must be matched in upper and lower byte connection. For example, D0-D7, DQM0, DQS0/DQS0_B D56-D63, DQM7, DQS7/DQS7_B should be in same byte connection.        |  |  |  |  |  |

| Layout checking list |                                                                                                                                       |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1                    | $100\Omega$ differential impedance control (DQS and CLK signals) and $50\Omega$ impedance control (data ,address and control signals) |  |  |  |  |
| 2                    | Match each differential signals pair ± 5 mils.                                                                                        |  |  |  |  |
| 3                    | All signals should be ground referenced and routed over a continuous plane. Please click "Refa4" for more info.                       |  |  |  |  |
| 4                    | The spacing between CLK and other signals should at least three times the trace width.                                                |  |  |  |  |
| 5                    | DDR routing rules. Please click "Ref-a5" or find sheet "MX6 DRAM Bus Length Check" for more info.                                     |  |  |  |  |

There is an Excel page named "MX6 DRAM Bus Length Check" in "HW Design Checking List for i.Mx6". Designer can use it for layout self-checking.

Input trace length of the design into cells in pink circle then, the bottom cell in same column may change to red color if layout breaks the rule.

## Freescale i.MX6 "T-topology" DRAM PCB Layout Trace Length Calculation

Note: Please fill the LIL length

If the table filled with RED color, please check the related error data.

| DRAM: (Left Top)                    |                     |       |                  | DRAM: (Right Top) |                |                       |                     |       |                  |                |                |
|-------------------------------------|---------------------|-------|------------------|-------------------|----------------|-----------------------|---------------------|-------|------------------|----------------|----------------|
| ADDR Graup                          | Longth<br>L1 (mile) | L0+L1 | ADDR-CKmin<br>(- | ADDR-<br>CKmex    | Ruuta<br>Layar | ADDR Graup            | Longth<br>L1 (mile) | L0+L1 | ADDR-CKmin<br>(- | ADDR-<br>CKmex | Ruuta<br>Layar |
| A.                                  | 1417.45             | MIR.5 | -58.55           | -58.79            | $\Box$         | A.                    | 1421.25             | M2X3  | -F4C3            | -55.6          | $\top$         |
| A1                                  | 1426.82             | M2K # | -50.70           | -50.00            |                | A1                    | 1428.49             | M2R.F | -47. f           | -487           |                |
| A2                                  | 1432.4              | MSEV  | -74.60           | -44.66            |                | A2                    | 1424.99             | M25.0 | -50.6            | -52.2          |                |
| A3                                  | 1423.64             | MER 6 | -500.0X          | -500.00           |                | A3                    | 1420.16             | MZR.Z | -FE V            | -57.0          |                |
| A4                                  | 1428.87             | MERR  | -48.83           | -46.63            |                | A4                    | 1430.29             | MSR3  | -450.3           | -46.6          |                |
| A5                                  | 1422.21             | M22.2 | -54.79           | -54.79            |                | A5                    | 1412.88             | MIZ.6 | -62.7            | -643           | $\top$         |
| A6                                  | 1421.87             | MELE  | -55.33           | -55,32            |                | A6                    | 1431.09             | MSLL  | -W.5             | -VC7           | $\top$         |
| A7                                  | 1422.72             | M22.7 | -54.28           | -54.28            |                | A7                    | 1423.5              | M2R5  | -52.6            | -533.6         | $\top$         |
| A‡                                  | 1420.05             | M2R7  | -56.65           | -56.65            |                | A‡                    | 1421.6              | MESS  | -50.9            | -55.5          | $\top$         |
| A9                                  | 1429.57             | MERK  | +400 400         | -450.450          |                | A9                    | 1424.64             | MENT  | -50.6            | -52.5          | $\top$         |
| A10                                 | 1424.41             | MENT  | -52.59           | -52.59            |                | A10                   | 1425.68             | M25.7 | -48.8            | -515           | $\top$         |
| A11                                 | 1422.46             | M22.5 | -54.54           | -54.54            |                | A11                   | 1429.8              | MZRIF | -VSC 7           | -450.5         | $\top$         |
| A12                                 | 1420.02             | MZR # | -56.66           | -56.66            |                | A12                   | 1426.59             | MZK.K | -78.0            | -50.6          | $\top$         |
| A13                                 | 1429.45             | M28.5 | -471.55          | -47.55            |                | A13                   | 1422.45             | M22.5 | -537             | -547           |                |
| A14                                 | 1413.94             | MRA   | -63.06           | -63.06            |                | A14                   | 1419.91             | MRR   | -550.6           | -57.2          | $\top$         |
| A15                                 |                     |       |                  |                   |                | A15                   |                     |       |                  |                | $\top$         |
| BA                                  | 1408.46             | MORE  | -68.54           | -68.54            |                | BAO                   | 1415.52             | MIRE  | -66.6            | -63.6          | $\top$         |
| BA1                                 | 1427.47             | MERS  | -98.50           | -49.50            |                | BA1                   | 1422.97             | MERR  | -527             | -542           | $\top$         |
| BA2                                 | 1427.47             | MERS  | -49.50           | -49050            | $\top$         | BA2                   | 1422.97             | MERIO | -52.6            | -542           | $\top$         |
| Hex diff<br>(c-25mil)               | 28.6                |       |                  |                   |                | Hex diff<br>(c-25mil) | 162                 |       |                  |                |                |
| Max diff<br>(c-25mil)<br>ADDR group |                     |       |                  |                   |                |                       |                     |       |                  |                |                |

# 2 DDR3 initialization Script Generation Aid

In this chapter we will show how to generate DDR3 initialization script for a specific design.

Since DDR3 initialization script has many registers; JESD79-3 and board design knowledge are required for configuration. It is very time consuming to generate it for dedicated design.

Freescale AE team created "i.Mx6DQSDL DDR3 Script Aid" for making this work easier. The latest Excel aid can be found through following link: <a href="https://community.freescale.com/docs/DOC-94917">https://community.freescale.com/docs/DOC-94917</a>

## 2.1 How to use the Aid?

Both schematic and DDR3 chip Datasheet which used in the schematic should be ready for reference. All "Orange" and "Blue" cells should be input properly.

| Device Information                    |                   |  |  |  |  |  |
|---------------------------------------|-------------------|--|--|--|--|--|
| Manufacturer:                         | Micron            |  |  |  |  |  |
| Memory part number:                   | MT41K128M16JT-125 |  |  |  |  |  |
| Memory type:                          | DDR3-1600         |  |  |  |  |  |
| DRAM density (Gb)                     | 2                 |  |  |  |  |  |
| DRAM Bus Width                        | 16                |  |  |  |  |  |
| Number of Banks                       | 8                 |  |  |  |  |  |
| Number of ROW Addresses               | 14                |  |  |  |  |  |
| Number of COLUMN Addresses            | 10                |  |  |  |  |  |
| Page Size (K)                         | 2                 |  |  |  |  |  |
| Self-Refresh Temperature (SRT)        | Normal            |  |  |  |  |  |
| tRCD=tRP=CL (ns)                      | 13.75             |  |  |  |  |  |
| tRC Min (ns)                          | 48.75             |  |  |  |  |  |
| tRAS Min (ns)                         | 35                |  |  |  |  |  |
| System Information                    |                   |  |  |  |  |  |
| i.Mx Part                             | i.Mx6Q            |  |  |  |  |  |
| Bus Width                             | 64                |  |  |  |  |  |
| Density per chip select (Gb)          | 8                 |  |  |  |  |  |
| Number of Chip Selects used           | 1                 |  |  |  |  |  |
| Total DRAM Density (Gb)               | 8                 |  |  |  |  |  |
| DRAM Clock Freq (MHz)                 | 528               |  |  |  |  |  |
| DRAM Clock Cycle Time (ns)            | 1.894             |  |  |  |  |  |
| Address Mirror (for CS1)              | Disable           |  |  |  |  |  |
| SI Configuration                      |                   |  |  |  |  |  |
| DRAM DSE Setting - DQ/DQM (ohm)       | 48                |  |  |  |  |  |
| DRAM DSE Setting - ADDR/CMD/CTL (ohm) | 48                |  |  |  |  |  |
| DRAM DSE Setting - CK (ohm)           | 48                |  |  |  |  |  |
| DRAM DSE Setting - DQS (ohm)          | 48                |  |  |  |  |  |
| System ODT Setting (ohm)              | 60                |  |  |  |  |  |

#### 2.1.1 Device information

All the inputs below can be obtained from chip Datasheet

Manufacturer: Type chip vendor name in the row

We use Micron as an example in this section.

Memory part number: Type full part/order number of chip in this row

We use MT41K128M16JT-125 as an example in this section. Chip Datasheet can be found through below link.

http://www.micron.com/~/media/Documents/Products/Data%20Sheet/DRAM/DDR3/2Gb\_1\_35V\_DDR3L.pdf

Memory Type: Select chip type in the list of this row

| Memory type:      | DDR3-1600 -            |
|-------------------|------------------------|
| DRAM density (Gb) | DDR3-800<br>DDR3-1066  |
| DRAM Bus Width    | DDR3-1006<br>DDR3-1333 |
| Number of Banks   | DDR3-1600              |

MT41K128M16JT-125 Datasheet shows below info.

Example Part Number: MT41K256M8DA-125:K



DRAM density (Gb): Select density of each chip in the list of this row



DRAM Bus Width: Select bus width of each chip in the list of this row

| DRAM Bus Width          | 16 | • |
|-------------------------|----|---|
| Number of Banks         | 4  |   |
| Number of ROW Addresses | 16 |   |

Number of Banks: Type band numbers of chip in this row

MT41K128M16JT-125 Datasheet shows below info.

## DDR3L SDRAM

MT41K512M4 – 64 Meg x 4 x 8 banks MT41K256M8 – 32 Meg x 8 x 8 banks MT41K128M16 – 16 Meg x 16 x 8 banks

Number of ROW Addresses: Select Row Address numbers of chip in the list of this row

| Number of ROW Addresses        | 14 🔻       |
|--------------------------------|------------|
| Number of COLUMN Addresses     | 11         |
| Page Size (K)                  | 12<br>13   |
| Self-Refresh Temperature (SRT) | 14<br>- 15 |
| tRCD=tRP=CL (ns)               | 16         |

MT41K128M16JT-125 Datasheet shows below info.

| Parameter      | 128 Meg x 16          |  |  |  |
|----------------|-----------------------|--|--|--|
| Configuration  | 16 Meg x 16 x 8 banks |  |  |  |
| Refresh count  | 8K                    |  |  |  |
| Row address    | 16K A[13:0]           |  |  |  |
| Bank address   | 8 BA[2:0]             |  |  |  |
| Column address | 1K A[9:0]             |  |  |  |

Number of COLUMN Addresses: Select Column Address numbers of chip in the list of this row

| Number of COLUMN Addresses     | 10 🔻     |
|--------------------------------|----------|
| Page Size (K)                  | 9        |
| Self-Refresh Temperature (SRT) | 10<br>11 |
| tRCD=tRP=CL (ns)               | 12       |

Page Size (K): Select page size of chip in the list of this row

| Page Size (K)                  | 2 🔻 |
|--------------------------------|-----|
| Self-Refresh Temperature (SRT) | 1   |
| IDAD IDD AL / \                | 2   |

Self-Refresh Temperature (SRT): Select SRT type of chip in the list of this row



tRCD=tRP=CL (ns): Type tRCD/tRP/CL parameter of chip in this row MT41K128M16JT-125 Datasheet shows below info.

| Speed Grade          | Speed Grade Data Rate (MT/s) |          | <sup>t</sup> RCD (ns) | <sup>t</sup> RP (ns) | CL (ns) |  |
|----------------------|------------------------------|----------|-----------------------|----------------------|---------|--|
| -125 <sup>1, 2</sup> | 1600                         | 11-11-11 | 13.75                 | 13.75                | 13.75   |  |

tRC Min (ns): Type tRC parameter of chip in this row

tRAS Min (ns): Type tRAS parameter of chip in this row

MT41K128M16JT-125 Datasheet shows below info.

| DDR3L-1600 Speed Bin                           | -12              |       |                       |      |
|------------------------------------------------|------------------|-------|-----------------------|------|
| CL-tRCD-tRP                                    | 11-1             | 1-11  |                       |      |
| Parameter                                      | Symbol           | Min   | Max                   | Unit |
| ACTIVATE-to-ACTIVATE or REFRESH command period | <sup>t</sup> RC  | 48.75 | -                     | ns   |
| ACTIVATE-to-PRECHARGE command period           | <sup>t</sup> RAS | 35    | 9 x <sup>t</sup> REFI | ns   |

## 2.1.2 System information

All below input can be gotten from schematic.

We use SABRE Board for Smart Devices as an example in this section. The design file can be found through below link.

https://www.freescale.com/webapp/sps/download/license.jsp?colCode=iMX6\_SABRE\_SDB\_DESIGNFILES&appType=file2&location=null&DOWNLOAD\_ID=null

i.Mx Part: Select i.Mx type in the list of this row

| i.Mx Part                    | i.Mx6Q ▼          |
|------------------------------|-------------------|
| Bus Width                    | i.Mx6Q            |
| Density per chip select (Gb) | i.Mx6D<br>i.Mx6DL |
| Number of Chip Selects used  | i.Mx6S            |

Bus Width: Select used i.Mx DRAM bus width in the list of this row

| Bus Width                    | 64       | T |
|------------------------------|----------|---|
| Density per chip select (Gb) | 16       |   |
| Number of Chip Selects used  | 32<br>64 |   |

Density per chip selects (Gb): Select total density of each CS in the list of this row

| Density per chip select (Gb) | 8        | ¥ |
|------------------------------|----------|---|
| Number of Chip Selects used  | 2        |   |
| Total DRAM Density (Gb)      | 8        |   |
| DRAM Clock Freq (MHz)        | 16<br>32 |   |

Number of Chip Selects used: Select numbers of CS are used in the list of this row

| Number of Chip Selects used | 1 🔻 |
|-----------------------------|-----|
| Total DRAM Density (Gb)     | 1   |
|                             | 12  |

DRAM Clock Freq (MHz): Select target DRAM working frequency in the list of this row



Address Mirror (for CS1): Select address mirror function in the list of this row



## 2.1.3 SI (Signal Integrity) Consideration

The inputs below can be based on SI design experience or simulation result.

General speaking drive strength (DSE) and ODT should match the characteristic impedance of transmission line. Actual test report of trace impedance should be delivered by PCB vendor.

For example, for 45 ohm single end trace DSE can select 40ohm or 48ohm; for 100ohm differential trace DSE of one pin of pair can select 48ohm etc.

About ODT selection, it isn't sensitive like DSE and can work well with a larger margin. For above example both single and differential case, 60 ohm should be fine.

DRAM DSE Setting - DQ/DQM (ohm): Select DQ/DQM pads driver strength value in the list of this row



DRAM DSE Setting - ADDR/CMD/CTL (ohm): Select ADDR/CMD/CTL pads driver strength value in the list of this row

DRAM DSE Setting - CK (ohm): Select CK pads driver strength value in the list of this row

DRAM DSE Setting - DQS (ohm): Select DQS pads driver strength value in the list of this row

System ODT Setting (ohm): Select ODT value for both DDR3 and i.Mx in the list of this row



## 2.2 Delay lines - which should according real board

Except parameters in section 2.1, designer also need fill four delay lines (Write Leveling delay, Read DQS Gating Delay, Read Delay, Write Delay) in script.

## 2.2.1 What are delay lines working for?

MMDC PHY Write Leveling Delay Control Register:

The write leveling calibration can generate a delay between the clock and the write DQS for each byte MMDC PHY Read DQS Gating Control Register:

The read DQS gating calibration is used to adjust the read DQS gating with the middle of the read DQS preamble.

MMDC PHY Read delay-lines Configuration Register:

This register controls read delay-lines functionality; it determines DQS delay relative to the associated DQ read access. The delay-line compensates for process variations and produces a constant delay regardless of the process, temperature and voltage.

MMDC PHY Write delay-lines Configuration Register:

This register controls write delay-lines functionality, it determines DQ/DM delay relative to the associated DQS in write access. The delay-line compensates for process variations, and produces a constant delay regardless of the process, temperature and voltage.

Detailed configuration descriptions about above registers can be found in i.Mx6 Reference Manual.

There are red marked registers in page "RealView.inc" of "i.Mx6DQSDL DDR3 Script Aid"

// For target board, may need to run write leveling calibration to fine tune these settings. setmem /32 0x021b080c = 0x000000000

| 7                               |              |            |                   |
|---------------------------------|--------------|------------|-------------------|
| setmem /32                      | 0x021b0810 = | 0x00000000 |                   |
| setmem /32                      | 0x021b480c = | 0x00000000 |                   |
| setmem /32                      | 0x021b4810 = | 0x00000000 |                   |
| ////Read DQS Gating calibration |              |            | _                 |
| setmem /32                      | 0x021b083c = | 0x00000000 | // MPDGCTRL0 PHY0 |
| setmem /32                      | 0x021b0840 = | 0x00000000 | // MPDGCTRL1 PHY0 |
| setmem /32                      | 0x021b483c = | 0x00000000 | // MPDGCTRL0 PHY1 |
| setmem /32                      | 0x021b4840 = | 0x00000000 | // MPDGCTRL1 PHY1 |
| //Read calibration              |              |            |                   |
| setmem /32                      | 0x021b0848 = | 0x40404040 | // MPRDDLCTL PHY0 |
| setmem /32                      | 0x021b4848 = | 0x40404040 | // MPRDDLCTL PHY1 |
| //Write calibration             |              |            |                   |
| setmem /32                      | 0x021b0850 = | 0x40404040 | // MPWRDLCTL PHY0 |
| setmem /32                      | 0x021b4850 = | 0x40404040 | // MPWRDLCTL PHY1 |

## 2.2.2 How to achieve them?

Freescale AE team had build a tool named "i.MX6 DDR Stress Test Tool" which can be run on and achieve all delay lines parameters of target board. Please download latest version through following link: <a href="https://community.freescale.com/docs/DOC-96412">https://community.freescale.com/docs/DOC-96412</a>

Next chapter will introduce how to use the tool.

## 3 DDR Stress Test Tool

The DDR stress test tool serves two purposes.

First, it can perform calibrations for DDR3 to match the MMDC PHY delay settings with PCB for optimal DRAM performance. The process is fully automatic, and therefore the customers can get there DDR3 working in much shorter time.

In addition, the tool can run a memory stress test to verify the DDR3 functionality as well as the reliability. The stress test can help verifying the hardware connections, MMDC registers parameters, and DDR3 mode registers setting. The most important purpose of the test is that it allows the customers to verify that the DDR3 operations are stable on their board.

#### 3.1 Calibration

There are four calibration processes required for DDR3 on i.MX6 processors. These calibration processes fine tune the delay registers on the MMDC PHY to compensate the skew between signals due the pads output delay variance and traces length difference to obtain the best DRAM performance.

The calibration will start on the DDR Stress Test Tool after entering the DDR3 configuration. First, the test will prompt for the DRAM frequency on calibration. The default value for i.MX6Q and i.MX6D is 528MHz. For i.MX6DL, i.MX6S, and i.MX6SL, the default value is 400MHz. These are the DRAM frequencies used by BSP. Press 'y' to proceed with the calibration process. There is an option to select a specific frequency by press 'n'. It should be only be used for debugging only.

```
Calibration will run at DDR frequency 528MHz. Type 'y' to continue.

If you want to run at other DDR frequency. Type 'n'
Enter the DDR frequency for calibration [350MHz to 528MHz]:

400

The freq you entered was: 400

DDR Freq: 396 MHz
```

After ending the DRAM frequency, then the tool will start the calibrations.

## 3.1.1 Write Leveling Calibration

This is the first calibration for fine tuning the delay between DRAM clock and write DQS output from i.MX6 processor. Press 'y' to continue with the calibration. If the board has been calibrated and calibration result had been integrated into script, press 'n' to skip the calibration.

After pressing 'y' to start the calibration, you need to enter the value of Mode Register MR1 for the DDR3. The MR1 value can be located on the following line on the initialization script. The value is the two most significant bytes after the '=' sign, i.e. 0x0004 on this example.

This value must be the same as the one used on the DDR initialization script. Otherwise, the results in the following parts of the test are invalid as this value is used for recovering the MR1 value on the DDR3 when leaving the write leveling mode.

```
Administrator: Command Prompt - DDR_Stress_Tester.exe -t mx6x -df scripts\MX6_series_boards\SabreS... \_ \_ \_

Would you like to run the write leveling calibration? (y/n)
Please enter the MR1 value on the initilization script
This will be re-programmed into MR1 after write leveling calibration
Enter as a 4-digit HEX value, example 0004, then hit enter

0004 You have entered: 0x00000004
Start write leveling calibration
Write leveling calibration
Write leveling calibration completed
MMDC_MPWLDECTRL0 ch0 after write level cal: 0x002A0021
MMDC_MPWLDECTRL1 ch0 after write level cal: 0x002E0028
MMDC_MPWLDECTRL1 ch1 after write level cal: 0x0016002C
MMDC_MPWLDECTRL1 ch1 after write level cal: 0x00140022
```

## 3.1.2 Read DQS Gating Calibration

The second calibration process is DQS gating calibration. It is used to fine tune the read DQS gating so that it could capture the read DQS signal reliably. The calibration adjusts the DQS gating delay in 4/256 clock cycle steps to locate the valid DQS delay window. Press 'y' to start the calibration. It will continue with the read and write delay calibration also. If the board has been calibrated and calibration result had been integrated into script, press 'n' to skip the calibration.

```
Administrator: Command Prompt
                                                                                                                   ould you like to run the DQS gating, read/write delay calibration? (y/n)
Starting DQS gating calibration...
BYTE 0:
                                    HC=0x01 ABS=0x58
HC=0x04 ABS=0x34
HC=0x03 ABS=0x06
HC=0x03 ABS=0x34
HC=0x03 ABS=0x34
           Start:
             nd-0.5*tCK:
BYTE 1:
            Mean:
End-0.5*tCK:
BYTE 2:
           Mean:
End-0.5*tCK:
Final:
BYTE 3:
            Start:
            Mean:
End-0.5*tCK:
Final:
BYTE 4:
            Mean:
            End-0.5*tCK:
BYTE 5:
BYTE 6:
BYTE 7:
                                        เกรดา
                                       =0×04
=0×02
            Mean:
End-0.5×tCK:
Final:
DQS calibration MMDC0 MPDGCTRL0 = 0 \times 43240334, MPDGCTRL1 = 0 \times 0234031C
DQS calibration MMDC1 MPDGCTRL0 = 0x43280334, MPDGCTRL1 = 0x03280270
```

The start and end of the valid DQS gating delay window for each byte will be shown after the calibration. The wider the valid window, i.e. the difference between start and end of the window is larger, implies more timing margin on the DQS gating delay. The mean of start and end of the window and end of the window minus half clock will also be shown as a reference. The suggested DQS delay will be shown as last and it is calculated by the formula max [mean (start, end), end-0.5tCK].

## 3.1.3 Read and Write Delay Calibrations

The last calibration processes are read and write delay calibrations. This is for fine tuning the delay between DQS and data on reading and writing DDR3 respectively. It helps to obtain the best timing between DQS and DQ signals. It will start after the DQS delay calibration is finish.

```
Administrator: Command Prompt
                                                                                                                                                                                                                    Array result[] holds the DRAM test result of each byte.
                0: test pass. 1: test fail
4 bits respresent the result of 1 byte.
result 00000001:byte 0 fail.
result 00000011:byte 0, 1 fail.
 Starting Read calibration...
 ABS_OFFSET=0×000000000
                                                                result[00]=0x11111111
result[01]=0x11111111

result[02]=0x11111111

result[02]=0x11111111

result[03]=0x01011011

result[04]=0x00011010

result[05]=0x00011000

result[06]=0x00011000
ABS_OFFSET=0x1818181818

ABS_OFFSET=0x1C1C1C1C

ABS_OFFSET=0x20202020

ABS_OFFSET=0x24242424

ABS_OFFSET=0x28282828

ABS_OFFSET=0x2626262

ABS_OFFSET=0x30303030

ABS_OFFSET=0x34343434
                                                                result [07]=0x00001000
result [08]=0x00000000
                                                                result[09]=0x000000000
                                                               ABS_OFFSET=0x38383838
ABS_OFFSET=0x3C3C3C3C3C
ABS_OFFSET=0x40404040
ABS_OFFSET=0x444444444
ABS_OFFSET =0×48484848
ABS_OFFSET =0×4C4C4C4C
ABS_OFFSET = 0×4C4C4C4C

ABS_OFFSET = 0×50505050

ABS_OFFSET = 0×5454545454

ABS_OFFSET = 0×58585858

ABS_OFFSET = 0×60606060

ABS_OFFSET = 0×64646464

ABS_OFFSET = 0×68686868

ABS_OFFSET = 0×670707070

ABS_OFFSET = 0×747474744

ABS_OFFSET = 0×7878787878
                                                               result[13]=0x00000000
result[14]=0x00000000
result[15]=0x00001000
result[16]=0x01001000
result[17]=0x11101110
result[18]=0x11101111
result[19]=0x11101111
result[1]=0x11101111
result[1]=0x11111111
result[1]=0x11111111
result[1]=0x11111111
result[1]=0x11111111
result[1]=0x11111111
         _OFFSET =0×78787878
                                                                result[1E]=0x1111111
 ABS_OFFSET=0×7C7C7C7C
                                                                result[1F]=0x11111111
 MMDC0 MPRDDLCTL = 0×38323636, MMDC1 MPRDDLCTL = 0×32323242
```

The format for read and write delay calibrations result are the same. The results are shown in increasing delay between DQS and DQ in 4/256 clock cycle steps. The results for each byte are shown with first byte on the first bit on the right, second byte on the second bit from the right and so on. For each byte, a "0" indicates a pass which mean the byte can perform a read/write reliably with that delay setting. A "1" indicates that the byte cannot pass the read/write test. The valid delay windows can be visualized by counting the number of 0 vertically. The wider the window implies the more margins for that byte.

#### 3.1.4 Calibration Results

After finishing all the calibration process, the calibration results are summarized and as shown below.

```
MMDC registers updated from calibration

Read DQS Gating calibration

MPDGCTRL0 PHY0 (0x021b083c) = 0x4148013C

MPDGCTRL1 PHY0 (0x021b0840) = 0x0130011C

Read calibration

MPRDDLCTL PHY0 (0x021b0848) = 0x42424446

Write calibration

MPWRDLCTL PHY0 (0x021b0850) = 0x3C3C3A32
```

The tool will proceed to run the DRAM stress test with the delay registers updated with these calibration results.

However, it is very important that these results should be recorded down and the DRAM initialization script should be updated accordingly. When porting the MMDC parameters to the firmware, the delay registers must be programmed according to the updated script. Otherwise, the DDR3 may not be able to run stably on the firmware.

#### 3.2 Stress Test

After finishing all the calibration processes, it tool will start the DRAM stress test. The stress test will perform read/write tests on the DDR3 with different patterns to ensure the DDR3 connections are correct, the MMDC parameters have been properly configured, and the PCB layout (and thus the signal integrity) is good for the DDR3 running reliably at the target operation frequency.

The stress test can run repeatedly on a single frequency or with incrementing frequencies. When the test starts, it will prompt for the start and end frequencies. For incrementing frequencies test, enter the start and end frequencies accordingly. The frequency has to be in the range of 135 MHz to 672 MHz Since tCK(AVG).MIN=3ns limits when DLL enable and script from "Aid" only support DLL enable, so please set DDR3 working point higher than 333MHz. If it is desired to test a single frequency, simply enter the same number for both start and end frequencies.

```
Administrator: Command Prompt
The DDR stress test can run with an incrementing frequency or at a static freq
To run at a static freq, simply set the start freq and end freq to the same value
Would you like to run the DDR Stress Test (y/n)?
Enter desired START freq (135 to 672 MHz), then hit enter.
Note: DDR3 minimum is ~333MHz, do not recommend to go too much below this.
   The freq you entered was: 400
Enter desired END freq (135 to 672 MHz), then hit enter.
Make sure this is equal to or greater than start freq
   The freq you entered was: 450
Beginning stress test
loop: 1
DDR Freq: 396 MHz
t0: memcpy11 SSN test
to: memcpy11 SSN test
t1: memcpy8 SSN test
t2: byte-wise SSN test
t3: memcpy11 random pattern test
t4: IRAM_to_DDRv2 test
t5: IRAM_to_DDRv1 test
t6: read noise walking ones and zeros test
DDR Freg: 413 MHz
t0: memcpy11 SSN test
t0: memcpy11 SSN test
t1: memcpy8 SSN test
t2: byte-wise SSN test
t3: memcpy11 random pattern test
t4: IRAM_to_DDRv2 test
t5: IRAM_to_DDRv1 test
t6: read noise walking ones and zeros test
DDR Freq: 432 MHz
t0: memcpy11 SSN test
```

The test will stop if any error occurs, the failure pattern will also be shown.

It is suggested to run the stress test at the target DDR3 operating frequency (528 MHz for i.MX6Q and i.MX6D; 400 MHz for i.MX6DL, i.MX6S, and i.MX6SL) for an extended period of time to verify the DDR3 performance on the target board. Running the stress test higher than the target operating frequency is not meaningful. The DDR3 waveform is not simple square wave in 400 – 500 MHz range that the DDR3 is operating. The signal waveform may change a lot as the frequency increases. Therefore, passing the stress test at a frequency higher than the target operating frequency does not necessarily mean that there is more timing margin.

BTW, we strongly suggest customer applying real high loading SW application case under corner environment condition to verify stability both SW and HW.

## 3.3 Using the DDR Stress Test Tool for Troubleshooting DDR3

When first bringing up a new PCB, it must run the calibrations to obtain the optimal delay registers setting for the board. It is an important step; the setting on default initialization script fine tuned the delay registers on Freescale Evaluation Board only. Without the calibration, the DDR3 might be affected even if all the AC timing related MMDC registers have been configured properly.

## 3.3.1 Identifying Issue on Calibrations

During the calibration processes, the valid delay window is shown for each calibration (except Write Leveling Calibration). The delay windows us a rough idea how much timing margin on read DQS, and data setup and hold time for DDR3 read and write operations. In general, the wider the window, the board has more time margin. The delay windows on Freescale Evaluation boards can be used as reference. The DQS gating delay window on Freescale board is around 1.1 to 1.2 tCK. For read and write delay, the window is around 0.3 to 0.4 tCK.

There is a chance that there is an error during the calibration, it may fail to find a valid delay window for some particular bytes. In such a case, DO NOT use the calibration result and proceed with the rest of the tests even the tool may show a result after the calibration finish!

If the tool fails to find a valid window for a byte, it would be a good idea to fine tune the drive strength of both DQS and DQ of that byte. The AC timing parameters should be configured properly as valid windows could be found on other bytes. The example below shows that byte 0 always fails on read calibration, meaning that the byte fail to read no matter which delay value is used. Ideally, the drive strength should match the trace impedance. If the information is not available, you could increase or decrease the drive strength and see if there is any improvement. If there is still no improvement after changing the drive strength, it should be the time to check the PCB layout. Design rules can be found in "HW Design Checking List for i.Mx6".

```
ABS OFFSET=0x00000000
                          result[00]=0x01010:01
ABS OFFSET=0x04040404
                          result[01]=0x01010:01
ABS OFFSET=0x08080808
                          result[02]=0x01010101
                          result[03]=0x01010:01
ABS OFFSET=0x0C0C0C0C
ABS OFFSET=0x10101010
                          result[04]=0x01010:01
ABS OFFSET=0x14141414
                          result[05]=0x01010:01
                          result[06]=0x01000101
ABS OFFSET=0x18181818
ABS OFFSET=0x1C1C1C1C
                          result[07]=0x000000<mark>:</mark>01
                          result[08]=0x000000[01
ABS OFFSET=0x20202020
                          result[09]=0x000000[01
ABS OFFSET=0x24242424
ABS OFFSET=0x28282828
                          result[0A]=0x000000<mark>0</mark>01
ABS OFFSET=0x2C2C2C2C
                          result[OB]=0x0000000001
ABS OFFSET=0x30303030
                          result[OC]=0x000000<mark>0</mark>01
ABS OFFSET=0x34343434
                          result[OD]=0x000000<mark>0</mark>01
                          result[OE]=0x0000000001
ABS OFFSET=0x383838383
                          result[OF]=0x000000(01
ABS OFFSET=0x3C3C3C3C
ABS OFFSET=0x40404040
                          result[10]=0x000000<mark>0</mark>01
ABS OFFSET=0x444444444
                          result[11]=0x0000000001
ABS OFFSET=0x48484848
                          result[12]=0x000000 01
ABS OFFSET=0x4C4C4C4C
                          result[13]=0x0000000001
ABS OFFSET=0x50505050
                          result[14]=0x0000000001
                          result[15]=0x000000<mark>0</mark>01
ABS OFFSET=0x54545454
ABS OFFSET=0x58585858
                          result[16]=0x0000000001
ABS OFFSET=0x5C5C5C5C
                          result[17]=0x01010[01
ABS OFFSET=0x60606060
                          result[18]=0x01010(<mark>0</mark>1
ABS OFFSET=0x64646464
                          result[19]=0x01010(<mark>0</mark>1
ABS OFFSET=0x68686868
                          result[1A]=0x01010:01
ABS OFFSET=0x6C6C6C6C
                          result[1B]=0x0101010101
ABS OFFSET=0x70707070
                          result[1C]=0x01010:01
                                               01
ABS OFFSET=0x74747474
                          result[1D]=0x01010:
ABS OFFSET=0x78787878
                          result[1E]=0x01010:01
ABS OFFSET=0x7C7C7C7C
                          result[1F]=0x01010:
```

## 3.3.2 Identifying Issue on Stress Test

The stress test will stop when an error is found. The address for the memory location that the error occurs and the error pattern will be printed out as in the examples below.

In this example, an error is found when reading back the data on address pattern test. The report reports an error as the memory content should be the same as the address, i.e. 0x10000000. The stress test reports an error because the data read from the address is 0xfd0000ff instead.

```
DDR Freq: 396 MHz
tO.1: data is addr test
Address of failure: 0x10000000
Data was: 0xfd0000ff
But pattern should match address
```

In this second example, an error is found when reading back the data that is written with a specific pattern. In this case, DATA[2] is supposed to be 0 but it is found to be run. Therefore, we could focus on check hardware and drive strength for byte 0 in this case.

Address of failure: 0x12000040
Data was: 0x04000400
But pattern was: 0x04040404

In case the board fails the stress test at target frequency, we can run the test with incrementing frequencies to check what is the highest frequency that the DDR3 can run properly. This test could give us an idea the problem is due to an error on the DDR3 connections, improper MMDC settings or poor PCB layout.

If the DDR3 cannot even pass the stress test at a low frequency, say 200 MHz, it is more likely to be a hardware problem. Then, it would be a good starting point to check the DDR3 connections. In addition, you should check the power supply for the DDR3, i.MX6 MMDC and DDR3 I/O to see if voltage is valid and ripple is not too large.

If case the board cannot pass the stress test at the target frequency but it can pass the stress test at a slightly lower frequency, you could try fine tuning the drive strength of the DDR3 I/O. It is also a good idea to re-visit the MMDC parameters and see if all of the AC timing can be met at the target frequency.

# 4 Further Reading

In order to make user better understanding DDR3 script, some configuration examples will be showed in this Chapter.

Due to limitation knowledge of author, some errors are unavoidable.

I will appreciate if someone can enter comments into following link: https://community.freescale.com/docs/DOC-94917

The DDR3/DDR3L interface mode of i.Mx6 fully complies with JESD79-3D DDR3 JEDEC standard release.

Latest JESD79-3 standard document can be downloaded through below link. http://www.jedec.org/standards-documents/results/taxonomy%3A3193

## 4.1 DDR3 Device Related Configurations

In i.Mx6DQ Reference Manual, we use 44.12.5 MMDC Core Timing Configuration Register 0 (MMDCx MDCFG0) as an example.

The register MMDCx\_MDCFG0 is corresponding below row in page "RealView.inc" of "i.Mx6DQSDL DDR3 Script Aid".

Field info of MMDCx\_MDCFG0 is showed.

Address: Base address + Ch offset

| BIt    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11  | 10  | 9 | 8 | 7 | 6   | 5 | 4 | 3 | 2  | 1 | 0      |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|-----|-----|---|---|---|-----|---|---|---|----|---|--------|
| R<br>W |    |    |    | tR | FC |    |    |    |    |    |    | tX | S  |    |    |    |    | tXP |    |    | tXP | DLL |   |   | t | FAV | v |   |   | tC | L | $\neg$ |
| Doent  | -  | 0  | 4  | 4  | _  | _  | 4  | 0  | 0  | 0  | 4  | 4  | _  | 4  | 4  | 0  | 0  | 0   | 4  | 0  | 0   | 0   | 4 | 0 | 4 | 4   | _ | 4 | 0 | 0  | 4 | _      |

#### tXPDLL field detailed info can be found in following table.

| 12-9   | Exit precharge power down with DLL frozen to commands requiring DLL.                                                                                       |  |  |  |  |  |  |  |  |  |  |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| tXPDLL | This field is not relevant in LPDDR2 mode.                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
|        | See DDR3 SDRAM Specification JESD79-3E (July 2010) and LPDDR2 SDRAM Specification JESD209-2B (February 2010) for a detailed description of this parameter. |  |  |  |  |  |  |  |  |  |  |  |
|        | 0x0 1 clock<br>0x1 2 clocks<br>0x2 3 clocks<br>0xE 15 clocks<br>0xF 16 clocks                                                                              |  |  |  |  |  |  |  |  |  |  |  |

Below table is extracted from "Table 68 — Timing Parameters by Speed Bin" in JESD79-3.

|                                       | DDR3-  | 800        | DDR3-1 | .066       | DDR3-1 | 333        | 3 DDR3-1 |            |     |  |  |
|---------------------------------------|--------|------------|--------|------------|--------|------------|----------|------------|-----|--|--|
| Parameter Parameter                   | Symbol | Min        | Max    | Min        | Max    | Min        | Max      | Min        | Max |  |  |
| Exit Precharge Power Down with DLL    | tXPDLL | max(10nCK, | -      | max(10nCK, | -      | max(10nCK, | -        | max(10nCK, | -   |  |  |
| frozen to commands requiring a locked |        | 24ns)      |        | 24ns)      |        | 24ns)      |          | 24ns)      |     |  |  |
| DLL                                   |        |            |        |            |        |            |          |            |     |  |  |

Target speed is 528MHz in the design. We can get tCK approximate 1.894ns.

Using column DDR3-1600 parameter, max (10nCK, 24ns)/1.894ns=24ns/1.894ns=12.67

Then tXPDLL should be 13 clocks and register value should be 0x0C according tXPDLL field in RM.

tFAW field detailed info can be found in following table.

| 8–4<br>tFAW | Four Active Window (all banks).                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | See DDR3 SDRAM Specification JESD79-3E (July 2010) and LPDDR2 SDRAM Specification JESD209-2B (February 2010) for a detailed description of this parameter. |
|             | 0x0 1 clock<br>0x1 2 clocks                                                                                                                                |
|             | 0x2 3 clocks<br>0x1E 31 clocks                                                                                                                             |
|             |                                                                                                                                                            |

Related define is extracted from "Table 68 — Timing Parameters by Speed Bin" in JESD79-3 as below.

|                                        |        | DDR3- | 800 | DDR3-1 | 1066 | DDR3-1 | 1333 | DDR3-1 |     |       |
|----------------------------------------|--------|-------|-----|--------|------|--------|------|--------|-----|-------|
| Parameter                              | Symbol | Min   | Max | Min    | Max  | Min    | Max  | Min    | Max | Units |
| Four activate window for 1KB page size | tFAW   | 40    | -   | 37.5   | -    | 30     | -    | 30     | -   | ns    |
| Four activate window for 2KB page size | tFAW   | 50    | -   | 50     | -    | 45     | -    | 40     | -   | ns    |

2Gb = 128Mx16 (2K page size) is used

Following second row of column DDR3-1600, 40ns/1.894ns = 21.12

Then tFAW should be 22 clocks and register value should be 0x15 according tFAW field in RM.

## 4.2 System Design Related Configurations

tRFC field detailed info can be found in following table.

|      | Refresh command to Active or Refresh command time.                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tRFC | See DDR3 SDRAM Specification JESD79-3E (July 2010) and LPDDR2 SDRAM Specification JESD209-2B (February 2010) for a detailed description of this parameter. |
|      | 0x0 1 clock<br>0x1 2 clocks<br>0x2 3 clocks                                                                                                                |
|      | 0xFE 255 clocks<br>0xFF 256 clocks                                                                                                                         |

Related define is extracted from "Table 61 — Refresh parameters by device density" in JESD79-3 as below.

| Parameter                                 | Symbol | 512Mb | 1Gb | 2Gb | 4Gb | 8Gb | Units |
|-------------------------------------------|--------|-------|-----|-----|-----|-----|-------|
| REF command to ACT or<br>REF command time | tRFC   | 90    | 110 | 160 | 260 | 350 | ns    |

Based on known info, tRFC = 160ns/1.894ns=84.5.

Then tRFC should be 85 clocks and register value should be 0x54 according tRFC field in RM.

#### 4.3 **SI Related Configurations**

In i.Mx6DQ Reference Manual, we use 36.4.350 Pad Control Register (IOMUXC SW PAD CTL PAD DRAM SDCLKO P) as an example.

The register IOMUXC SW PAD CTL PAD DRAM SDCLKO P is corresponding below row in page "RealView.inc" of "i.Mx6DQSDL DDR3 Script Aid".

setmem /32

0x020e0588 =

0x00000028 // IOMUXC SW PAD CTL PAD DRAM SDCLK 0

Field info of IOMUXC SW PAD CTL PAD DRAM SDCLKO P is showed.



DSE field detailed info can be found in following table.

```
Drive Strength Field
DSE
         Select one of next values for pad: DRAM_SDCLK_0.
         000 HIZ — HI-Z
         001 240_OHM — 240 Ohm
         010 120 OHM — 120 Ohm
              80 OHM - 80 Ohm
         011
              60_OHM -- 60 Ohm
         100
              48_OHM — 48 Ohm
         101
              40 OHM - 40 Ohm
              34 OHM - 34 Ohm
```

As mentioned in section 2.1.3, the register can be configured by default based on SI design experience simulation result.